![untitled](data:image/jpeg;base64,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)

**United** International **University** (UIU)

Dept. of Electrical and Electronic Engineering (EEE)

# **Course**: VLSI Design Lab (EEE 442)

**Experiment 4: Physical Design of a Counter**

Introduction:

1. Switch to csh, this will also setup your cadence tools environment variables

* csh

1. Create the lab directory and few other sub-directories under your work area:

* mkdir lab4
* cd lab4
* mkdir lib constraints lef physical\_design netlist

1. Copy the gate level netlist from previous lab into the netlist/ sub-directory

* cp ../lab3/synthesis/cntr8bit\_netlist.v netlist/

1. Copy the SDC constraint from previous lab into the constraints/ sub-directory

* cp ../lab3/synthesis/cntr8bit.sdc constraints /

1. Copy the .lib files from previous lab into the lib/ sub-directory

* cp ../lab3/lib/\*.lib lib/

1. Copy the LEF (Library Exchange Format) file from ~sahmed/eee442/lab4/lef/

* cp ~sahmed/eee442/lab4/lef/all.lef lef/

1. Go to physical\_design/ and invoke Innovus Tool to do the Place & Route the design. This will launch the Innovus Tool in the GUI mode.

* cd physical\_design
* innovus

DESIGN IMPORT

1. Click on *File 🡪 Import Design* menu option. This will open the *Design Import* window.
2. Under *Netlist:* option choose *Verilog*. Click on the browse button to select the gate level netlist from the netlist/ sub-directory
3. Under *Top Cell:* option select *Auto Assign:*
4. Under *Technology/Physical Libraries:* option select *LEF Files:* Click on the browse button and select all.lef file from lef/ sub-directory
5. Under *Power* option use **VDD** as *power Nets:* **VSS** as *Ground Nets:*
6. Under *analysis Configuration* option click on the *Create Analysis Configuration* button.
7. An *MMMC Browser* window will open.
8. Double click on *Library Sets*. *Add Library Set* window will open. *Name:* it as **max\_timing** and click on ‘Add…’ button under ‘Timing Library Files’
9. Set **max\_timing** to ‘slow.lib’ and **min\_timing** to ‘fast.lib’ under the lib/ sub-directory.
10. Double click on *Delay Corners*. *Add Delay Corner* window will appear. *Name:* it as **min\_delay**. In the ‘Library Set’ option under ‘Attributes’, scroll to **min\_timing** and click ‘OK’
11. Similarly set **max\_delay** to **max\_timing**.
12. Double click on *Constraints Modes*. *Add Constraint Mode* window will open. *Name:* it as **counter\_constraints** and click on ‘Add…’ button under ‘CDS Constraint Files’
13. Set **counter\_constraints** to ‘cntr8bit.sdc’ under constraints/ sub-directory.
14. Double click on *Analysis Views*. *Add Analysis View* window will open. *Name:* it as **worst\_case** and select **max\_delay** for *Delay Corner* and click ‘OK’
15. Similarly set **best\_case** to **min\_delay**.
16. Double click on *Setup Analysis Views*. *Add Setup Analysis Views* window will open. Set the *Analysis View* to **worst\_case**. Click ‘OK’
17. Double click on *Hold Analysis Views*. *Add Hold Analysis Views* window will open. Set the *Analysis View* to **best\_case**. Click ‘OK’
18. *MMMC Browser* will look as below: Click on ‘Save & Close’.
19. *Save MMMC View Definition File* window will open. Provide the *File name:* as **Default.view** and click on ‘Save’
20. Click ‘OK’ on the *Design Import* window. This will load the design into Innovus

FLOOR PLANNING

1. Click *Floorplan 🡪 Specify Floorplan* menu option. This will open the ‘Specify Floorplan’ window.
2. Select aspect ratio as per requirement. Give some dimension in ‘Core to Left’, ‘Core to Right’, ‘Core to Top’ and ‘Core to Bottom’. (Remember the values are in µm) to create space for Power Rings. After defining code are, click ‘OK’

POWER PLANNING

1. Click on *Power 🡪 Power Planning 🡪 Add Rings* menu option. This will open ‘Add Rings’ window
2. Type/Select **VDD** and **VSS** nets under the *Net(s)* option.
3. Select top/bottom layers as Metal5, left/right layers as Metal6. Make sure the metal layer names match with that of all.lef file in lef/ sub-directory. Set the width/space as per requirement (unit is in µm) and taking the space between core boundary and I/O pad consideration. Select the option for offset as ‘Center in channel’ and click ‘OK’
4. Power ring will be created between core boundary and IO/Die boundary
5. Click *Power 🡪 Power Planning 🡪 Add Stripe* menu option. This will open ‘Add Stripes’ window
6. Type/Select **VDD** and **VSS** nets under the *Net(s)* option.
7. Select *Layer:* as Metal6 and *Direction:* as *Vertical*. Make sure the metal layer names and direction match with that of all.lef. Set width/spacing as per requirement (unit is in µm). Choose one of the *Set* Pattern, use *Core ring* as the *Stripe Boundary*, set the *First/Last Stripe* staring from *left*. Click ‘OK’.
8. Vertical power stripe will be created.
9. Perform steps 34, 35 and 36 to create horizontal stripes if needed.
10. Click *Route 🡪 Special Route* menu option. This will open ‘SRoute’ window
11. Type/Select **VDD** and **VSS** nets under the *Net(s)* option.
12. Choose any of the options I*Follow Pins* for standard cells) that you want to ruote under *SRoute*
13. Choose the *Top/Bottom Layer* and other option as needed. Click ‘OK’
14. This will create the standard cell rails and others if chosen

PLACEMENT

1. Click *Place 🡪 Place Standard Cells* menu option. This will open ‘Place’ window
2. Select ‘Run Full Placement’, choose ‘Include Pre-Place Optimization’ under *Optimization Option*. Click ‘OK’
3. Click on the *Physical View* to see the standard cells.

PRE-CTS TIMING

1. Click *Timing 🡪 Report Timing* menu option. This will open ‘Timing Analysis’ window
2. Select ‘Pre-CTS’ under *Design Stage* and ‘Setup’ under *Analysis Type*. Click ‘OK’
3. This will display the timing information on the Innovus terminal. Carefully check the Worst Negative Slack (WNS) and Total Negative Slack (TNS).
4. If there are WNS/TNS, click on *Optimize 🡪 Optimize Design* menu option. This will open ‘Optimization’ window
5. Select ‘Pre-CTS’ under *Design Stage* and ‘Setup’, ‘Max Cap’ and ‘Max Tran’ under *Optimization Type*. Click ‘Ok’. This will optimize the design. Check timing again. Repeat until timing is met.

CLOCK TREE SYNTHESIS

1. Click *Clock 🡪 Synthesize Clock Tree…’* menu option. This will open ‘Synthesize Clock Spec’ window
2. Click on ‘Gen Spec…’ This will open ‘Generate Clock Spec’ window
3. From *Cells List* select all cells starting with ‘CLK’ and click on ‘Add’ button to add them to the *Selected Cells*. Give a name for the *Output Specification File:* and click ‘OK’.
4. Give a name for the *Result Directory:* in the ‘Synthesis Clock Tree’ window. Click ‘OK’

ROUTING

1. …
2. …

VERIFICATION

1. Geometry
2. Connectivity
3. …

GDS Out

1. …